home *** CD-ROM | disk | FTP | other *** search
/ Reverse Code Engineering RCE CD +sandman 2000 / ReverseCodeEngineeringRceCdsandman2000.iso / RCE / Ebooks / Thinking in Java / c16 / recycleb / RecycleB.java
Encoding:
Java Source  |  2000-05-25  |  3.9 KB  |  113 lines

  1. //: RecycleB.java
  2. //////////////////////////////////////////////////
  3. // Copyright (c) Bruce Eckel, 1998
  4. // Source code file from the book "Thinking in Java"
  5. // All rights reserved EXCEPT as allowed by the
  6. // following statements: You can freely use this file
  7. // for your own work (personal or commercial),
  8. // including modifications and distribution in
  9. // executable form only. Permission is granted to use
  10. // this file in classroom situations, including its
  11. // use in presentation materials, as long as the book
  12. // "Thinking in Java" is cited as the source. 
  13. // Except in classroom situations, you cannot copy
  14. // and distribute this code; instead, the sole
  15. // distribution point is http://www.BruceEckel.com 
  16. // (and official mirror sites) where it is
  17. // freely available. You cannot remove this
  18. // copyright and notice. You cannot distribute
  19. // modified versions of the source code in this
  20. // package. You cannot use this file in printed
  21. // media without the express permission of the
  22. // author. Bruce Eckel makes no representation about
  23. // the suitability of this software for any purpose.
  24. // It is provided "as is" without express or implied
  25. // warranty of any kind, including any implied
  26. // warranty of merchantability, fitness for a
  27. // particular purpose or non-infringement. The entire
  28. // risk as to the quality and performance of the
  29. // software is with you. Bruce Eckel and the
  30. // publisher shall not be liable for any damages
  31. // suffered by you or any third party as a result of
  32. // using or distributing software. In no event will
  33. // Bruce Eckel or the publisher be liable for any
  34. // lost revenue, profit, or data, or for direct,
  35. // indirect, special, consequential, incidental, or
  36. // punitive damages, however caused and regardless of
  37. // the theory of liability, arising out of the use of
  38. // or inability to use software, even if Bruce Eckel
  39. // and the publisher have been advised of the
  40. // possibility of such damages. Should the software
  41. // prove defective, you assume the cost of all
  42. // necessary servicing, repair, or correction. If you
  43. // think you've found an error, please email all
  44. // modified files with clearly commented changes to:
  45. // Bruce@EckelObjects.com. (Please use the same
  46. // address for non-code errors found in the book.)
  47. /////////////////////////////////////////////////
  48.  
  49. // Adding more objects to the recycling problem
  50. package c16.recycleb;
  51. import c16.trash.*;
  52. import java.util.*;
  53.  
  54. // A vector that admits only the right type:
  55. class Tbin extends Vector {
  56.   Class binType;
  57.   Tbin(Class binType) { 
  58.     this.binType = binType; 
  59.   }
  60.   boolean grab(Trash t) {
  61.     // Comparing class types:
  62.     if(t.getClass().equals(binType)) {
  63.       addElement(t);
  64.       return true; // Object grabbed
  65.     }
  66.     return false; // Object not grabbed
  67.   }
  68. }
  69.  
  70. class TbinList extends Vector { //(*1*)
  71.   boolean sort(Trash t) {
  72.     Enumeration e = elements();
  73.     while(e.hasMoreElements()) {
  74.       Tbin bin = (Tbin)e.nextElement();
  75.       if(bin.grab(t)) return true;
  76.     }
  77.     return false; // bin not found for t
  78.   }
  79.   void sortBin(Tbin bin) { // (*2*)
  80.     Enumeration e = bin.elements();
  81.     while(e.hasMoreElements())
  82.       if(!sort((Trash)e.nextElement()))
  83.         System.out.println("Bin not found");
  84.   }
  85. }
  86.  
  87. public class RecycleB {
  88.   static Tbin bin = new Tbin(Trash.class);
  89.   public static void main(String[] args) {
  90.     // Fill up the Trash bin:
  91.     ParseTrash.fillBin("Trash.dat", bin);
  92.  
  93.     TbinList trashBins = new TbinList();
  94.     trashBins.addElement(
  95.       new Tbin(Aluminum.class));
  96.     trashBins.addElement(
  97.       new Tbin(Paper.class));
  98.     trashBins.addElement(
  99.       new Tbin(Glass.class));
  100.     // add one line here: (*3*)
  101.     trashBins.addElement(
  102.       new Tbin(Cardboard.class));
  103.  
  104.     trashBins.sortBin(bin); // (*4*)
  105.  
  106.     Enumeration e = trashBins.elements();
  107.     while(e.hasMoreElements()) {
  108.       Tbin b = (Tbin)e.nextElement();
  109.       Trash.sumValue(b);
  110.     }
  111.     Trash.sumValue(bin);
  112.   }
  113. } ///:~